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Agenda 


Kernel-space 


o  NVIF 

o Power management 
User-space 

o OpenGL 


o Performance Counters 
o OpenCL/Vulkan 


Firmware overview 
Tegra & Maxwell support 
Cooperation with NVIDIA 
Who are we”? 


Introduction 


e Last complete update was at XDC 2015 
e Many improvements since then :) 


Kernel / Lib DRM 


e Initial Pascal support merged (Linux 4.8) 
o  Modesetting enabled for all Pascals 
o Acceleration requires firmwares from NVIDIA 
= Only GP100 available right now ($10k GPU)... 


e NVIF 
o Allows the userspace to access some kernel structures and functions 
o Would allow Nouveau to run in guest virtual machines, without Virgl. 
o Support now merged in the kernel (Linux 4.3) and libdrm 


Kernel / Lib DRM 


e Power management 

o PCI-E link is now changed when setting a pstate 

o More GPUs can be reclocked 
m G94-G200 are now reclockable (Linux 4.4) 
m Initial steps for proper GPU boost on Fermi+ (Linux 4.9) 
m Initial Maxwell reclocking support (Linux 4.9) 

o Power consumption monitoring merged (Linux 4.9) 

o Work by Karol Herbst, presented tomorrow (see the program) 


Mesa - Current Status 


e Mesa 12.0: 
o Support GM20x GPUs 
o OpenGL 4.3, ES 3.1 for Fermi/Kepler! 
o And... a bunch of various bugfixes and optimizations 


e Next Mesa release: 
o Initial support GP10x GPUs 
o OpenGL 4.1 for Maxwell/Pascal! 
o Work done by llia Mirkin, Samuel Pitoiset and Ben Skeggs 


Mesa - Future Work 


e OpenGL: 
o Ultimate goal: OpenGL 4.5 
o OpenGL 4.3 for Maxwell/Pascal 
m Sched code data calculator (WIP) 

o Implement new features on GM200+ 
Vertex/tess shader viewport/layer setting 
Post-depth coverage 
Geometry broadcasting to multiple viewports 
Conservative rasterization 
New rectangle primitive 

= Configurable sample locations 
o More bugfixes 
o Perf, perf, perf! 


Performance counter status 


e Current status: 
o Libdrm-2.4.66: Expose the PM engine and NVIF interface 
o Graphics perf counters already RE’d for Fermi 


e Plan: 
o Rework the queries in NVCO (ie. allow batching) (WIP) 
o Monitor perf counters and expose them to the Gallium HUD (WIP) 
o RE more perf counters on Kepler+ 


e Development is stalled, GL features first! 


Mesa 


e OpenCL: 
o Cf. FOSDEM 2016 (https://archive.fosdem.org/2016/schedule/event/nv_compute/) 
o Updates for SPIR-V -> NV50 IR part: 

m Code updated to support Fermi, Kepler and Maxwell: 
clCreateProgramWithBinary and clCreateProgramWithIL supported; 
Improved support for if statements; 

Basic phi-node removal pass; 
Most atomic operations now supported; 

m Use the correct signedness for operations; 
o Future Work: 

= Textures/surfaces support (WIP); 

= ARB gi spirv support; 

m Code cleanup and upstreaming. 


e Vulkan: 
o Don’t expect something soon 
o See you at XDC’17! :) 


Maxwell/Pascal Firmware Release 


On GM20x+, FECS and PMU firmwares should be signed NVIDIA to work. 


Current status: 


e NVIDIA did provide code for loading them on Tegra and dGPUs 
e GRAPH signed firmwares released for GM20x (Feb. 2016) and GP100 (Jul. 
2016) 


Needed firmwares: 


e FECS (PGRAPH) 
o Performs context switching 
o Blocks 2D/3D/Video acceleration 
e PMU (PDAEMON): 
o Performs power management 
o Blocks fan management, efficient dynamic reclocking and power gating 


Tegra Support 


e GK20A (Tegra K1), released in January 2014 
o Continuous effort by NVIDIA ever since 
March 2014: support for non-PCl(e)/AGP platforms (Linux 3.15) 
June 2014: Initial support for 2D/3D rendering (Linux 3.16) 
July 2014: support for manual reclocking (Linux 3.17) 
October 2014: Mesa support 


July 2015: FECS/GPCCS firmware merged into linux-firmware 
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e GM20B (Tegra X1), released in January 2015 

August 2015: Basic kernel support merged (Linux 4.3) 
Reclocking, power management in the pipe 

Advanced features (framebuffer compression, ...) also planned 
February 2016: Signed firmware released 
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Applications still require support to display properly on Tegra 


Maxwell and Pascal Support 


e GM10x (Released in February 2014) 
o September 2014: Initial support (Linux 3.15) 
o June 2015: Out of the box acceleration support (Linux 4.1) 
o November 2016: Full manual reclocking support (Linux 4.9) 


e GM20x (Released in September 2014) 
o February 2016: NVIDIA released the firmwares 
o March 2016: Acceleration support (Linux 4.6) 
o Power management stalled! Waiting on NVIDIA’s signed PMU firmware 


e GP10x (Released in July 2016) 
o October 2016: Initial support for GP100/GP104 (Linux 4.8) 
o October 2016: Acceleration support for GP100 (Linux 4.8) 
o — Stalled! Waiting on NVIDIA’s signed GRAPH firmwares (GP102+) 


Relationship with NVIDIA, since 2013 


e NVIDIA side 

Official support of Tegra GPUs 

Register dumps for the TK1 provided 

Implemented secure boot on Nouveau 

Some open documentation (download.nvidia.com/open-gpu-doc/) 

Mailing-list where Nouveau developers can ask questions to NVIDIA engineer 


github. 
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e Nouveau side 
o Waiting for signed firmwares, ... for years ... 
Preventing fan management, and therefore reclocking on GM2xx 
No acceleration on Pascal 
Waiting for the BIOS documentation ... since REing is blocked by the signed vbios ... 
Losing interest in new platforms 
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NVIDIA, please allow us to help you... 


What we would need 


e Early access to hardware and firmwares: 
o NDAs are fine as long as they expire the day hardware ships! 
o Documentation for firmwares’ ABI 


e Rights to redistribute firmwares... 
o On the day of release 


e \VBIOS documentation 
o And a way to disable signature checking for the bios (to verify the documentation) 


e Adapt internal FW policy to public releases (?) 


o Do we really need to do this? We know this is not gonna happen and we could live with 
changes anyway due to the architecture of Nouveau. 


Failing this: 


e The Nouveau community will shrink as the driver becomes irrelevant for users 
e NVIDIA will have to write support for newer chips and convince us that they 
will actually maintain the code. 


Who are we? 


Special thanks to the following Nouveau developers for their work: 


e Ben Skeggs (Red Hat) - Main kernel developer and maintainer of 
nouveau-drm 

e |lia Mirkin and Samuel Pitoiset - Main developers of the mesa driver 

e And, in alphabetic order: 
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Alexandre Courbot (NVIDIA) - Tegra K1+ development and maintenance 
Hans de Goede and Pierre Moreau - OpenCL support 

Karol Herbst and Roy Spliet - Power management and performance 
Martin Peres - Power and thermal management (drm-side) 

Emil Velikov - Fixes and robustness of the mesa code 


e You? We are looking for: 


O 
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Compiler developer enthusiasts to write compiler optimisations 
Quality Assurance contributors - Grab the code from git and test it! 


Useful status links 


General news: http://nouveau.freedesktop.org/ 

Feature matrix: https://nouveau.freedesktop.org/wiki/FeatureMatrix/ 
Video decoding: http://nouveau.freedesktop.org/wiki/VideoAcceleration/ 
OpenGL status: https://people.freedesktop.org/~imirkin/glxinfo/ 

Task list: https://trello.com/b/ZudRDiTL/nouveau 


